$(function() {
    // 1.1 获取裁剪区域的 DOM 元素
    var $image = $('#image')
        // 1.2 配置选项
    const options = {
        // 纵横比
        aspectRatio: 1,
        // 指定预览区域
        preview: '.img-preview'
    }

    // 1.3 创建裁剪区域
    $image.cropper(options)


    // 头像上传分三步:
    // 1.选择图片;  2.渲染图片  3.上传头像
    $("#chooseImageBtn").on('click', function() {
        $("#chooseImageInp").click();
    });

    // 渲染图片; change 选择文件时触发的事件;value值发生改变触发这个事件
    $("#chooseImageInp").on("change", function() {
        // console.log(this.value);
        // 1.获取文件对象
        let file = this.files[0];
        if (file === undefined) {
            return layui.layer.msg("上传头像,不能为空!")
        }
        let url = URL.createObjectURL(file);
        // console.log(url);
        $image
            .cropper('destroy') // 销毁旧的裁剪区域
            .attr('src', url) // 重新设置图片路径
            .cropper(options) // 重新初始化裁剪区域
    });

    // 3.上传头像;
    $("#uploadBtn").on("click", function() {
        // 将 剪裁区域的图片，转化为 base64 格式的字符串
        var dataURL = $image
            .cropper('getCroppedCanvas', { // 创建一个 Canvas 画布
                width: 100,
                height: 100
            })
            .toDataURL('image/png') // 将 Canvas 画布上的内容，转化为 base64 格式的字符串
            // console.log(dataURL);
        axios({
            method: 'POST',
            url: '/my/update/avatar',
            data: "avatar=" + encodeURIComponent(dataURL)
        }).then(res => {
            if (res.data.status !== 0) {
                return layui.layer.msg(res.data.message);
            }
            layui.layer.msg("恭喜您,更改用户头像成功!");
            window.parent.getUserInfo();
        });
    });
});